SDMAY25-28 CAMDEN FERGEN JOHN HUARACHA NICHOLAS LYNCH CALVIN SMITH LEVI WENCK

# DIGITAL ASIC DESIGN FACULTY PANEL PRESENTATION

<u>Client and</u> <u>Faculty Advisor:</u> Professor Duwe





## PROJECT OVERVIEW

#### • Problem

- Non-Flexible ISAs
  - Re-fabricate if you want to test/use a new instruction
- Lack of physical processors for student to learn from
  - Hardware student learn through software simulations or FPGAs
- Solution: Reprogrammable RISC-V Processor
  - Extending the RISC-V ISA to support custom instructions
  - Using a CGRA called "CyGRA" for programmable instruction
  - Support for memory and I/O

#### EFABLESS

#### • OpenLANE

 $\bigcap$ 

- Compilation of open-source tools
- Verilog HDL to IC Layout
- $\odot$  Provides test for generated ICs
- Caravel Harness
  - User Project Area
  - Management Area
    - Signals
      - Clock
      - Logic Analyzer
      - Wishbone
      - IRQ
    - VexRISC-V



From Efabless

#### USERS







#### CHIP FORGE CLUB MEMBERS

#### HARDWARE STUDENTS

#### PROFESSORS

Design Document | PG. 9

sdmay25-28 | 4

## FUNCTIONAL REQUIREMENTS

- Overall design contains a RISC-V processor
  - Can execute RISC-V machine code
  - Must be open source
- Custom instruction support
  - User should be able to program custom instruction into a custom instruction module
  - Users should be able to call and execute the custom instruction loaded
- Users can load in programs in memory and execute

## NON-FUNCTIONAL REQUIREMENTS

- Project should be user-friendly
  - User-friendly interface for loading instructions and programming the CyGRA
  - Comprehensive and clear documentation
- Custom instruction should run within 1x-10x the CPI of a standard add instruction.
- Custom instruction should adhere to RISC-V ISA standards
- Efabless
  - Designs written in Verilog
  - $\bigcirc$  Firmware written in C
  - O Skywater 130nm process

## EFABLESS DESIGN CONSTRAINTS

- 2920 µm x 3520 µm wrapper area (10 mm<sup>2</sup>)
   O Dictates how much internal memory we can fit
- 40 MHz clock rate max
- Maximum of 34 I/O pins
  - Four used to communicate with SPI memory
    Others used for I/O devices

Design Document | PG. 10

## ENGINEERING STANDARDS



IEEE 1754-1994: IEEE Standard for a 32-bit Microprocessor Architecture

IEEE 1364-2001: IEEE Standard Verilog Hardware Description Language

IEEE 1364.1-2002: IEEE Standard for Verilog Register Transfer Level Synthesis

Wishbone Bus

SPI Protocol

Design Document | PG. 11

sdmay25-28 | 8

#### **HIGH-LEVEL DESIGN**

- PicoRV32 is a staged RISC-V processor.
- CyGRA is a CGRA that can be programmed and used by the PicoRV32 to execute custom instructions.
- Instruction memory written by management micro-controller through the wishbone bus.
- On-Chip Memory is used as cache for off-chip
- Off-Chip Memory is slower SPI memory.
- Logic Analyzers used to probe key parts of the project.
- IRQ module communicates with management core (VexRISC-V)



#### RISC-V CORE: PICORV32

- Open-Source
- Low-Size 32bit RISC-V processor
- Supports custom non-branching instruction using a Co-Processor Interface.
  - Allows us to easily integrate our CyGRA
- Written in Verilog

Design Document | PG. 25

 Same as caravel project which allows for easy integration



Simplified stages of the PicoRV32 processor with the CyGRA. Custom instruction branch with normal instruction at the decode stage and the custom instruction result follow the red arrows back to the Fetch stage.

#### ON-CHIP MEMORY

- Currently using Open-Source prehardened 512x32 bit DFFRAM
- Area  $\approx 1 \text{mm}^2$
- May experiment with other open-source memory solutions
   OpenRAM
  - DFFRAM Compiler



## CURRENT CYGRA DESIGN

- 2x2 fully configurable CGRA implementation
- 32-bit fixed point and integer arithmetic and bitwise operations
- Tightly coupled with picorv32
- Math.h, convolution, matrix multiplication



## ADDITIONAL COMPONENTS

- Wishbone Slave: Used to interface with management area MCU to write instruction memory On-Chip.
- SPI Main Unit: Used to communicate with external SPI memory.
- Memory Interface Unit: Manges internal and external memory and provides memory inputs and outputs. Used to manage the cache (onchip).



#### NOVEMBER TEST CHIP

- Design made for team sddec24-12 (Last semester's Digital ASIC project)
  - Goal: Put several projects on one Caravel chip
- Opportunity to gain experience tools
- Module hardened
- Module in Caravel wrapper hardened
- Testing
  - RTL/GL test written
    - Passes RTL
  - $\odot$  DRC and LVS checks pass
  - Pre-Check (Check before sending chip to be fabricated) passes





CURRENT PROGRESS: HARDENED WRAPPER WITH PICORV32 AND MEMORY

- Fully Synthesized
- 2KB of DFFRAM
- Passes Pre-check
- Can add other components onto wrapper once they are hardened and tested



# CUSTOM INSTRUCTION RUNNING ON SIMULATED PICORV32

- Co-Processor interface proven
- Implemented R-type instruction which performs unsigned addition of all bytes in a word
- Behavioral simulation tested

Design Document | PG. 32

| picorv32.v x coProc.v   | × picoCustom.v × Ur               | ntitled 2 $\times$    |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
|-------------------------|-----------------------------------|-----------------------|-----------|--------------|--------------------------------------|--------------|----------|-------------------------------------|-----------|-----------|-------------|----------|-------------|------|----------|----------|---------|----------|---------|
| Q 💾 🛛 Q 💥               | • I I I I I I I I I I I I I I I I | [ ] [e ] [e] ] [e] ]  |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
|                         |                                   |                       |           |              |                                      |              |          |                                     | 1,166.1   | 15 ns     |             |          |             |      |          |          |         |          |         |
| Name                    | Value                             |                       | 1,050.000 | Ins          | 1,10                                 | 0.000 ns     |          | 1,150.00                            | 0 ns      |           | 1,200.00    | 10 ns    |             | 1,25 | 0.000 1  | ns .     |         | 1,300.0  | 000 ns  |
| 🕌 clk                   | 0                                 |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
| 🐌 resetn                | 1                                 |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
| 🔓 trap                  | 0                                 |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
| 🔓 mem_valid             | 0                                 | 17 11                 |           | 7            |                                      |              |          |                                     |           |           |             |          | _           |      |          |          |         |          |         |
| 🔓 mem_instr             | 1                                 |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
| 🐌 mem_ready             | 0                                 |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
| > 😻 mem_addr[31:0]      | 000000c                           |                       | <u> </u>  | 00000004     |                                      | 00000008     |          | 0000                                | 000c      | X_        | 0000001     | 0        | 00000       | 014  | X        |          |         | 01010000 |         |
| > 😻 mem_wdata[31:0]     | XXXXXXXXXX                        |                       |           |              |                                      | X            | XXXXXXX  |                                     |           |           |             |          |             |      | X        |          |         | 0000002  |         |
| > 😻 mem_wstrb[3:0]      | 0                                 | X                     |           |              |                                      |              | 0        |                                     |           |           |             |          |             |      | X        |          |         | ļ f      |         |
| > 😻 mem_rdata[31:0]     | 01010037                          | XXXXXXXXXX 010        | 10037     | χ 01010      | 3Ob 7                                | 06008        | 133      | X                                   | 0101003   | 7         | 00          | 20a023   | X           |      |          |          | ffSff   | 06f      |         |
| 😼 pcpi_ada_valid        | 0                                 |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
| > 😻 pcpi_ada_insn[31:0] | 06008133                          | XXXXXXXXX             | 010       | 10037        | 010                                  | 10057        |          | 06008133                            |           | 01        | 010037      | _X       | 00203023    | 3    | X        |          |         | ff5ff06f |         |
| > 🕊 pcpi_ada_rs1[31:0]  | 01010000                          | xxxxxxxxxx X 00000000 |           |              |                                      |              |          | 0101 <mark>0</mark> 000 X 0000000 X |           |           |             | 01010000 |             |      |          |          |         |          |         |
| > 🕏 pcpi_ada_rs2[31:0]  | 00000000                          | XXXXXXXXX             |           | _X_          | 0000 <mark>0</mark> 000 X 01010000 X |              |          |                                     |           |           | 00000002    |          |             |      |          |          |         |          |         |
| 🖥 pcpi_ada_wr           | 1                                 |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |
| > 😻 pcpi_ada_rd[31:0]   | 00000002                          | X000000X              |           |              |                                      |              |          |                                     |           | 0000002   |             |          |             |      |          |          |         |          |         |
| 😼 pcpi_ada_wait         | х                                 |                       |           |              |                                      |              |          |                                     | 2         |           |             |          |             | 3    |          |          |         |          |         |
| 🔓 pcpi_ada_ready        | 1                                 |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          | (       |
| > 😻 memory[0:255][31:0] | 01010037,010100b7,060081          | 01010037,01010067,    | 06008133, | 01010037,002 | 0a023, ff5                           | ff06f,XXXXXX | XX, XXXX | XXXX, XXXXX                         | XXX, XXXX | XXXX, XXX | XXXXX, XXXX | XXXX, XX | XXXXXXX, XX |      | x, xxxxx | xxx, xx> | xxxxx,> | xxxxxxx, | XXXXXXX |
|                         |                                   |                       |           |              |                                      |              |          |                                     |           |           |             |          |             |      |          |          |         |          |         |

## BASIC C CODE RUNNING ON PICORV32

- RISCV toolchain scripts created for running C code on the picorv32
- Future accelerator code implementation will involve inline bytecode
- Needs incorporation with Efabless



Compilation and running in iverilog via testbench bytecode injection

sdmay25-28 | 17

| Verilog/Python<br>Testbenches                                 | C Code                                                          | FPGA Synthesis | Layout<br>Verification                        |
|---------------------------------------------------------------|-----------------------------------------------------------------|----------------|-----------------------------------------------|
| <ul> <li>Unit Tests</li> <li>Integration<br/>Tests</li> </ul> | <ul> <li>Integration<br/>Tests</li> <li>System Tests</li> </ul> | • System Tests | <ul><li>DRC</li><li>LVS</li><li>STA</li></ul> |

TEST PLAN

 $\bigcirc$ 

 $\bigcirc$ 

 $\bigcirc$ 

## TEST FLOW FOR MODULES IN A CARAVEL PROJECT

#### Caravel RTL Simulation

- Testbench Tool: CocoTB
- Test firmware written in C

#### • OpenROAD Hardening: DRC, LVS, and STA

- O DRC Tool: Magic
- O LVS Tool: Netgen
- STA Tool: OpenSTA

#### Caravel GL Simulation

- Structural Verilog representation of the layout
- O Reuses RTL testbench and firmware



State diagram showing the test flow of a module.

Design Document | PG. 30-32

sdmay25-28 | 19

#### WORKSPACE SETUP

#### • Gitlab

- Gitlab group to hold all repositories related to our project
- Gitlab modules setup
- Code issue tracking
- Virtual machines
  - Used to eliminate differences in setup
  - Helped streamline tooling setup

| s sdmay25-2                                      | 28-s ≞                  |               |
|--------------------------------------------------|-------------------------|---------------|
| ያ main ~ sdmay25-28                              | / + ~ History Find file | Edit Y Code Y |
| Merge branch 'new_re<br>ndlynch authored 1 month | epo' into 'main' 🚥      | 6435ae02 සී   |
| Name                                             | Last commit             | Last update   |
| 🗅 .github                                        | Added overflow detectio | 1 month ago   |
| 🗅 def                                            | Added overflow detectio | 1 month ago   |
| 🗅 docs                                           | Added overflow detectio | 1 month ago   |
| 는 gds                                            | Added overflow detectio | 1 month ago   |
| 🗅 lef                                            | Added overflow detectio | 1 month ago   |
| 🗅 lib                                            | Added overflow detectio | 1 month ago   |
| 🗅 lvs/user_project                               | Added overflow detectio | 1 month ago   |
| 🗅 mag                                            | Added overflow detectio | 1 month ago   |
| 🗅 maglef                                         | Added overflow detectio | 1 month ago   |
| 🗅 openlane                                       | Added overflow detectio | 1 month ago   |
| ট sdc                                            | Added overflow detectio | 1 month ago   |
| 🗅 signoff                                        | Added overflow detectio | 1 month ago   |
| 🗅 spef                                           | Added overflow detectio | 1 month ago   |
| 🗅 spi/lvs                                        | Added overflow detectio | 1 month ago   |
| 🗅 verilog                                        | Added overflow detectio | 1 month ago   |
| 🚸 .gitignore                                     | Added overflow detectio | 1 month ago   |
| 🖹 .readthedocs.yaml                              | Added overflow detectio | 1 month ago   |
|                                                  | Added overflow detectio | 1 month ago   |
| 🕒 Makefile                                       | Added overflow detectio | 1 month ago   |
| M# README.md                                     | Added overflow detectio | 1 month ago   |

|       |                                               | Project Lead | d C    | amden        |              |      |      |      | 16 Sep 2024                           | 23 Sep 2024                            | 30 Sep 2024          | 7 Oct 2024                         | 14 Oct 2024                           | 21 Oct 2024                           | 28 Oct 2024                        | 4 Nov 2            |
|-------|-----------------------------------------------|--------------|--------|--------------|--------------|------|------|------|---------------------------------------|----------------------------------------|----------------------|------------------------------------|---------------------------------------|---------------------------------------|------------------------------------|--------------------|
| WBS   | TASK                                          |              | LEAD   | START        | END          | DAYS | one  | WORK | 16 17 18 19 20 21 22<br>M T W T F S S | 2 23 24 25 26 27 28 2<br>M T W T F S S | 930123456<br>MTWTFSS | 7 8 9 10 11 12 13<br>M T W T F S S | 14 15 16 17 18 19 20<br>M T W T F S S | 21 22 23 24 25 26 27<br>M T W T F S S | 28 29 30 31 1 2 3<br>M T W T F S S | 4 5 6 7<br>M T W T |
| 1     | Project Prep                                  |              |        |              | -            |      |      | -    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.1   | Chip forge Tutorials                          |              | ALL    | Mon 9/16/24  | Mon 9/30/24  | 15   | 100% | 11   |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.2   | CprE 381 Lab hardening                        |              | Nick   | Mon 9/30/24  | Sun 10/27/24 | 28   | 100% | 20   |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.2.1 | Lab 1                                         |              | Nick   | Tue 10/01/24 | Mon 10/07/24 | 7    | 100% | 5    |                                       |                                        |                      |                                    |                                       |                                       | -                                  |                    |
| 1.2.2 | Lab 2                                         |              | Nick   | Tue 10/08/24 | Sun 10/27/24 | 20   | 100% | 14   |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.3   | RISC-v Knowledge                              |              |        | Mon 9/30/24  | Sun 10/06/24 | 7    | 100% | 5    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.4   | Acquire VMs for design                        |              | Camden | Mon 10/14/24 | Mon 10/28/24 | 15   | 100% | 11   |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.4.1 | Access VM                                     |              |        | Tue 10/15/24 | Wed 10/16/24 | 2    | 100% | 2    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.4.2 | Get basic setup done                          |              |        | Thu 10/17/24 | Fri 10/18/24 | 2    | 100% | 2    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.4.3 | Get required software instal                  | lled         |        | Sat 10/19/24 | Thu 10/24/24 | 6    | 100% | 4    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 1.4.4 | Test software to ensure fund                  | ctionality   | ALL    | Fri 10/25/24 | Mon 10/28/24 | 4    | 100% | 2    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 2     | Nov Chip 11/11/24                             |              |        |              | -            |      |      | -    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 2.1   | Passing precheck                              |              | Nick   | Fri 10/25/24 | Tue 10/29/24 | 5    | 100% | 3    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 2.2   | Confirm working                               |              | Nick   | Tue 10/29/24 | Sat 11/02/24 | 5    | 100% | 4    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |
| 2.3   | Work with dec24-12 to get desi<br>implemented | ign          | Nick   | Wed 10/30/24 | Thu 11/07/24 | 9    | 100% | 7    |                                       |                                        |                      |                                    |                                       |                                       |                                    |                    |

| 3       | Project Design                       |                  |              | -            |    |      | -  |
|---------|--------------------------------------|------------------|--------------|--------------|----|------|----|
| 3.1     | High level project design            | ALL              | Sun 11/10/24 | Wed 12/04/24 | 25 | 60%  | 18 |
| 3.1.1   | Basic project design                 |                  | Fri 11/15/24 | Fri 11/29/24 | 15 | 0%   | 11 |
| 3.1.2   | Memory integration                   |                  |              |              |    | 0%   | -  |
| 3.1.2.1 | Loading memory from Caravel          |                  |              |              |    | 0%   | -  |
| 3.1.2.2 | Reading memory from Caravel          |                  |              |              |    | 0%   |    |
| 313     | Accelerator/CGRA integration         |                  |              |              |    | 0%   |    |
| 2.1.4   | Management Area lategration          |                  |              |              |    | 0%   |    |
| 2444    | Mishhane Bus connection              |                  |              |              |    |      |    |
| 3.1.4.1 | Wishbolie Bus connection             |                  |              |              |    | -    |    |
| 3.2     | RISC-V core                          | Calv n Cam       | Wed 10/23/24 | Fri 11/01/24 | 10 | 100% | 8  |
| 3.2.1   | Research existing RISC-V IPs         |                  | Wed 10/23/24 | Sat 10/26/24 | 4  | 100% | 3  |
| 3.2.2   | Narrow to 3 IPs                      |                  | Sun 10/27/24 | Wed 10/30/24 | 4  | 100% | 3  |
| 3.2.3   | Decide on RISC-V IP                  |                  | Thu 10/31/24 | Fri 11/01/24 | 2  | 100% | 2  |
| 3.2.4   | Harden RISC-V IP (picorv32)          |                  | Wed 11/06/24 | Sun 11/10/24 | 5  | 100% | 3  |
| 3.2.5   | RISC-V Toolchain                     |                  |              | •            |    |      | -  |
| 3.3     | Accelerator design                   | John and<br>Levi | Mon 10/28/24 | Tue 11/26/24 | 30 | 100% | 22 |
| 3.3.1   | Determine specific usecase           |                  | Mon 10/28/24 | Sun 11/03/24 | 7  | 100% | 5  |
| 3.3.2   | Implement basic accelerator          |                  | Fri 11/08/24 | Sun 11/17/24 | 10 | 0%   | 6  |
| 3.3.3   | PICO ISA extension (add instruction) |                  |              |              | 1  | 0%   | -  |
| 3.3.4   | Simple instruction extension         |                  |              |              | 1  | 0%   | -  |
| 3.3.4.1 | Instruction design                   |                  |              |              | 1  | 0%   | -  |
| 3.3.5   | Pico test plan (Plan docs)           |                  |              | •            | 1  | 0%   | -  |
| 3.3.6   | Testing toolflow                     |                  |              | •            | 1  | 0%   | -  |
| 3.3.6.1 | Behavioral testing flow              |                  |              | •            | 1  | 0%   | -  |
| 3.3.6.2 | C code testing flow                  |                  |              |              | 1  | 0%   | -  |
| 3.3.7   | FPGA Testing flow                    |                  |              |              | 1  | 0%   |    |
|         |                                      |                  |              |              |    |      |    |

## PROJECT SCHEDULE

#### High Level Overview:

- Project Prep **Complete**
- November Chip Deadline **Complete**
- Project Design In-Progress
- Integration Future Step
- Testing Future Step

## PROJECT STATUS

| Complete                    | In-Progress           | Future Steps                          |
|-----------------------------|-----------------------|---------------------------------------|
| Virtual machine and Tooling | CyGRA Implementation  | Communication with<br>Management Area |
| November Chip               | PICO-RV ISA Extension | High-Level Behavioral Tests           |
| RISC-V Processor            | Module Design         | FPGA Testing                          |
| Accelerator Application     |                       | Precheck and Hardening                |

Design Document | PG. 14-16

#### TEAM ROLES

Camden Fergen – DevOps and Project Lead

- John Huaracha Testing Lead
- Nicholas Lynch Harden and Verification Lead
- Calvin Smith Accelerator Design Lead
- Levi Wenck Communication Interfaces Lead

## THANK YOU! QUESTIONS?

#### REFERENCES

- Benson, Duane. "Efabless Announces Custom SoC Design Platform for Edge Machine Learning." All About Circuits, 16 Oct. 2024. Accessed November 20, 2024
- CGRA Architecture and Tools | AHA Agile Hardware Project. https://aha.stanford.edu/research/cgraarchitecture-and-tools. Accessed October 11, 2024.
- Efabless Caravel "Harness" SoC Caravel Harness Documentation. https://caravelharness.readthedocs.io/en/latest/. Accessed September 20, 2024.
- "PicoRV32 A Size-Optimized RISC-V CPU." GitHub, https://github.com/YosysHQ/picorv32. Accessed October 30, 2024.
- Todd, Dillon. "Tightly Coupling the PicoRV32 RISC-V Processor with Custom Logic Accelerators via a Generic Interface." All Theses, May 2021, https://open.clemson.edu/all\_theses/3552. Accessed November 15, 2024.